//珂珂喜欢吃香蕉。这里有 n 堆香蕉，第 i 堆中有 piles[i] 根香蕉。警卫已经离开了，将在 h 小时后回来。 
//
// 珂珂可以决定她吃香蕉的速度 k （单位：根/小时）。每个小时，她将会选择一堆香蕉，从中吃掉 k 根。如果这堆香蕉少于 k 根，她将吃掉这堆的所有香蕉，然后
//这一小时内不会再吃更多的香蕉。 
//
// 珂珂喜欢慢慢吃，但仍然想在警卫回来前吃掉所有的香蕉。 
//
// 返回她可以在 h 小时内吃掉所有香蕉的最小速度 k（k 为整数）。 
//
// 
//
// 
// 
//
// 示例 1： 
//
// 
//输入：piles = [3,6,7,11], h = 8
//输出：4
// 
//
// 示例 2： 
//
// 
//输入：piles = [30,11,23,4,20], h = 5
//输出：30
// 
//
// 示例 3： 
//
// 
//输入：piles = [30,11,23,4,20], h = 6
//输出：23
// 
//
// 
//
// 提示： 
//
// 
// 1 <= piles.length <= 10⁴ 
// piles.length <= h <= 10⁹ 
// 1 <= piles[i] <= 10⁹ 
// 
//
// Related Topics 数组 二分查找 👍 549 👎 0


package LeetCode.editor.cn;

/**
 * @author ldltd
 * @date 2023-10-04 23:00:09
 * @description 875.爱吃香蕉的珂珂
 */
public class KokoEatingBananas{
	 public static void main(String[] args) {
	 	 //测试代码
	 	 Solution solution = new KokoEatingBananas().new Solution();

	 }
	 
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public int minEatingSpeed(int[] piles, int h) {
		int n = piles.length;
//		int maxVal= Arrays.stream(piles).max().getAsInt();
		int maxVal = 0;
		for (int pile : piles) {
			maxVal = Math.max(maxVal, pile);
		}
		int l=1,r=maxVal;
		if(h==n) return r;
		while (l<r){
			int m=l+(r-l)/2;
			if((cal(piles,m))>h){
			//时间大于h，速度太慢，下一轮在m+1到r搜索
				l=m+1;
			}else {
				r=m;
			}
		}
		return l;
	}
	private int cal(int [] piles,int k){
		int ret=0;
		for (int i = 0; i < piles.length; i++) {
			//向上取整
			ret+=(piles[i]+k-1)/k;
		}
		return ret;
	}
}
//leetcode submit region end(Prohibit modification and deletion)

}
